Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(search): Enhances query_string queries #4814

Open
wants to merge 5 commits into
base: main
Choose a base branch
from

Conversation

ERosendo
Copy link
Contributor

Fixes #3993 by updating build_text_filter to use the quote_field_suffix parameter.

Copy link
Member

@mlissner mlissner left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't really understand this code, but I did have a thought about the test, which I added. I'll let Alberto chime in!

Comment on lines 886 to 897
params = {
"type": SEARCH_TYPES.RECAP,
"q": 'cause:"31:3730 Qui Tam False Claims Act"',
}
async_to_sync(self._test_article_count)(
params, 2, "faceted_cause_query_string"
)
params = {
"type": SEARCH_TYPES.RECAP,
"cause": '"31:3730 Qui Tam False Claims Act"',
}
async_to_sync(self._test_article_count)(params, 2, "cause_filter")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it'd be helpful to pull the cause string out to show that it's the same in every instance:

Suggested change
params = {
"type": SEARCH_TYPES.RECAP,
"q": 'cause:"31:3730 Qui Tam False Claims Act"',
}
async_to_sync(self._test_article_count)(
params, 2, "faceted_cause_query_string"
)
params = {
"type": SEARCH_TYPES.RECAP,
"cause": '"31:3730 Qui Tam False Claims Act"',
}
async_to_sync(self._test_article_count)(params, 2, "cause_filter")
cause_str = "31:3730 Qui Tam False Claims Act"
params = {
"type": SEARCH_TYPES.RECAP,
# Do it in main query box
"q": f'cause:"{cause_str}"',
}
async_to_sync(self._test_article_count)(
params, 2, "faceted_cause_query_string"
)
params = {
"type": SEARCH_TYPES.RECAP,
# Do it in the cause field as a phrase
"cause": f'"{cause_str}"',
}
async_to_sync(self._test_article_count)(params, 2, "cause_filter")
params = {
"type": SEARCH_TYPES.RECAP,
# Do it in the cause field without quotes
"cause": f'{cause_str}',
}
async_to_sync(self._test_article_count)(
params, 2, "cause_filter_no_phrase"
)

I also added a test without quotes, which I hope will work?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it'd be helpful to pull the cause string out to show that it's the same in every instance:

Great idea. I'll update the code to reflect this change.

@mlissner mlissner assigned albertisfu and unassigned mlissner Dec 12, 2024
@mlissner mlissner requested a review from albertisfu December 12, 2024 18:28
Copy link
Contributor

@albertisfu albertisfu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good and resolves the issue for quoted queries within filters.

However, we were discussing that the test suggested without quotes in the filter is still failing. This is due to a combination of factors specific to these terms that cause synonyms applied at search time to mismatch the indexed terms. Eduardo will explain the detailed problem in a different issue so we can discuss it and choose the best trade-off to address it.

This is good to merge.

@ERosendo
Copy link
Contributor Author

However, we were discussing that the test suggested without quotes in the filter is still failing. This is due to a combination of factors specific to these terms that cause synonyms applied at search time to mismatch the indexed terms. Eduardo will explain the detailed problem in a different issue so we can discuss it and choose the best trade-off to address it.

@albertisfu Here's the issue: #4816

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: In progress
Development

Successfully merging this pull request may close these issues.

Inconsistent results from cause filter in RECAP Search
3 participants